home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2007 September / PCWSEP07.iso / Software / Linux / Linux Mint 3.0 Light / LinuxMint-3.0-Light.iso / casper / filesystem.squashfs / usr / src / linux-headers-2.6.20-15-generic / scripts / Makefile.build < prev    next >
Encoding:
Makefile  |  2007-04-12  |  10.4 KB  |  350 lines

  1. # ==========================================================================
  2. # Building
  3. # ==========================================================================
  4.  
  5. src := $(obj)
  6.  
  7. PHONY := __build
  8. __build:
  9.  
  10. # Read .config if it exist, otherwise ignore
  11. -include include/config/auto.conf
  12.  
  13. include scripts/Kbuild.include
  14.  
  15. # The filename Kbuild has precedence over Makefile
  16. kbuild-dir := $(if $(filter /%,$(src)),$(src),$(srctree)/$(src))
  17. include $(if $(wildcard $(kbuild-dir)/Kbuild), $(kbuild-dir)/Kbuild, $(kbuild-dir)/Makefile)
  18.  
  19. include scripts/Makefile.lib
  20.  
  21. ifdef host-progs
  22. ifneq ($(hostprogs-y),$(host-progs))
  23. $(warning kbuild: $(obj)/Makefile - Usage of host-progs is deprecated. Please replace with hostprogs-y!)
  24. hostprogs-y += $(host-progs)
  25. endif
  26. endif
  27.  
  28. # Do not include host rules unles needed
  29. ifneq ($(hostprogs-y)$(hostprogs-m),)
  30. include scripts/Makefile.host
  31. endif
  32.  
  33. ifneq ($(KBUILD_SRC),)
  34. # Create output directory if not already present
  35. _dummy := $(shell [ -d $(obj) ] || mkdir -p $(obj))
  36.  
  37. # Create directories for object files if directory does not exist
  38. # Needed when obj-y := dir/file.o syntax is used
  39. _dummy := $(foreach d,$(obj-dirs), $(shell [ -d $(d) ] || mkdir -p $(d)))
  40. endif
  41.  
  42.  
  43. ifdef EXTRA_TARGETS
  44. $(warning kbuild: $(obj)/Makefile - Usage of EXTRA_TARGETS is obsolete in 2.6. Please fix!)
  45. endif
  46.  
  47. ifdef build-targets
  48. $(warning kbuild: $(obj)/Makefile - Usage of build-targets is obsolete in 2.6. Please fix!)
  49. endif
  50.  
  51. ifdef export-objs
  52. $(warning kbuild: $(obj)/Makefile - Usage of export-objs is obsolete in 2.6. Please fix!)
  53. endif
  54.  
  55. ifdef O_TARGET
  56. $(warning kbuild: $(obj)/Makefile - Usage of O_TARGET := $(O_TARGET) is obsolete in 2.6. Please fix!)
  57. endif
  58.  
  59. ifdef L_TARGET
  60. $(error kbuild: $(obj)/Makefile - Use of L_TARGET is replaced by lib-y in 2.6. Please fix!)
  61. endif
  62.  
  63. ifdef list-multi
  64. $(warning kbuild: $(obj)/Makefile - list-multi := $(list-multi) is obsolete in 2.6. Please fix!)
  65. endif
  66.  
  67. ifndef obj
  68. $(warning kbuild: Makefile.build is included improperly)
  69. endif
  70.  
  71. # ===========================================================================
  72.  
  73. ifneq ($(strip $(lib-y) $(lib-m) $(lib-n) $(lib-)),)
  74. lib-target := $(obj)/lib.a
  75. endif
  76.  
  77. ifneq ($(strip $(obj-y) $(obj-m) $(obj-n) $(obj-) $(lib-target)),)
  78. builtin-target := $(obj)/built-in.o
  79. endif
  80.  
  81. # We keep a list of all modules in $(MODVERDIR)
  82.  
  83. __build: $(if $(KBUILD_BUILTIN),$(builtin-target) $(lib-target) $(extra-y)) \
  84.      $(if $(KBUILD_MODULES),$(obj-m)) \
  85.      $(subdir-ym) $(always)
  86.     @:
  87.  
  88. # Linus' kernel sanity checking tool
  89. ifneq ($(KBUILD_CHECKSRC),0)
  90.   ifeq ($(KBUILD_CHECKSRC),2)
  91.     quiet_cmd_force_checksrc = CHECK   $<
  92.           cmd_force_checksrc = $(CHECK) $(CHECKFLAGS) $(c_flags) $< ;
  93.   else
  94.       quiet_cmd_checksrc     = CHECK   $<
  95.             cmd_checksrc     = $(CHECK) $(CHECKFLAGS) $(c_flags) $< ;
  96.   endif
  97. endif
  98.  
  99.  
  100. # Compile C sources (.c)
  101. # ---------------------------------------------------------------------------
  102.  
  103. # Default is built-in, unless we know otherwise
  104. modkern_cflags := $(CFLAGS_KERNEL)
  105. quiet_modtag := $(empty)   $(empty)
  106.  
  107. $(real-objs-m)        : modkern_cflags := $(CFLAGS_MODULE)
  108. $(real-objs-m:.o=.i)  : modkern_cflags := $(CFLAGS_MODULE)
  109. $(real-objs-m:.o=.s)  : modkern_cflags := $(CFLAGS_MODULE)
  110. $(real-objs-m:.o=.lst): modkern_cflags := $(CFLAGS_MODULE)
  111.  
  112. $(real-objs-m)        : quiet_modtag := [M]
  113. $(real-objs-m:.o=.i)  : quiet_modtag := [M]
  114. $(real-objs-m:.o=.s)  : quiet_modtag := [M]
  115. $(real-objs-m:.o=.lst): quiet_modtag := [M]
  116.  
  117. $(obj-m)              : quiet_modtag := [M]
  118.  
  119. # Default for not multi-part modules
  120. modname = $(basetarget)
  121.  
  122. $(multi-objs-m)         : modname = $(modname-multi)
  123. $(multi-objs-m:.o=.i)   : modname = $(modname-multi)
  124. $(multi-objs-m:.o=.s)   : modname = $(modname-multi)
  125. $(multi-objs-m:.o=.lst) : modname = $(modname-multi)
  126. $(multi-objs-y)         : modname = $(modname-multi)
  127. $(multi-objs-y:.o=.i)   : modname = $(modname-multi)
  128. $(multi-objs-y:.o=.s)   : modname = $(modname-multi)
  129. $(multi-objs-y:.o=.lst) : modname = $(modname-multi)
  130.  
  131. quiet_cmd_cc_s_c = CC $(quiet_modtag)  $@
  132. cmd_cc_s_c       = $(CC) $(c_flags) -fverbose-asm -S -o $@ $<
  133.  
  134. %.s: %.c FORCE
  135.     $(call if_changed_dep,cc_s_c)
  136.  
  137. quiet_cmd_cc_i_c = CPP $(quiet_modtag) $@
  138. cmd_cc_i_c       = $(CPP) $(c_flags)   -o $@ $<
  139.  
  140. %.i: %.c FORCE
  141.     $(call if_changed_dep,cc_i_c)
  142.  
  143. quiet_cmd_cc_symtypes_c = SYM $(quiet_modtag) $@
  144. cmd_cc_symtypes_c       = \
  145.         $(CPP) -D__GENKSYMS__ $(c_flags) $<            \
  146.         | $(GENKSYMS) -T $@ >/dev/null;                \
  147.         test -s $@ || rm -f $@
  148.  
  149. %.symtypes : %.c FORCE
  150.     $(call if_changed_dep,cc_symtypes_c)
  151.  
  152. # C (.c) files
  153. # The C file is compiled and updated dependency information is generated.
  154. # (See cmd_cc_o_c + relevant part of rule_cc_o_c)
  155.  
  156. quiet_cmd_cc_o_c = CC $(quiet_modtag)  $@
  157.  
  158. ifndef CONFIG_MODVERSIONS
  159. cmd_cc_o_c = $(CC) $(c_flags) -c -o $@ $<
  160.  
  161. else
  162. # When module versioning is enabled the following steps are executed:
  163. # o compile a .tmp_<file>.o from <file>.c
  164. # o if .tmp_<file>.o doesn't contain a __ksymtab version, i.e. does
  165. #   not export symbols, we just rename .tmp_<file>.o to <file>.o and
  166. #   are done.
  167. # o otherwise, we calculate symbol versions using the good old
  168. #   genksyms on the preprocessed source and postprocess them in a way
  169. #   that they are usable as a linker script
  170. # o generate <file>.o from .tmp_<file>.o using the linker to
  171. #   replace the unresolved symbols __crc_exported_symbol with
  172. #   the actual value of the checksum generated by genksyms
  173.  
  174. cmd_cc_o_c = $(CC) $(c_flags) -c -o $(@D)/.tmp_$(@F) $<
  175. cmd_modversions =                            \
  176.     if $(OBJDUMP) -h $(@D)/.tmp_$(@F) | grep -q __ksymtab; then    \
  177.         $(CPP) -D__GENKSYMS__ $(c_flags) $<            \
  178.         | $(GENKSYMS) $(if $(KBUILD_SYMTYPES),            \
  179.                   -T $(@D)/$(@F:.o=.symtypes)) -a $(ARCH)    \
  180.         > $(@D)/.tmp_$(@F:.o=.ver);                \
  181.                                     \
  182.         $(LD) $(LDFLAGS) -r -o $@ $(@D)/.tmp_$(@F)         \
  183.             -T $(@D)/.tmp_$(@F:.o=.ver);            \
  184.         rm -f $(@D)/.tmp_$(@F) $(@D)/.tmp_$(@F:.o=.ver);    \
  185.     else                                \
  186.         mv -f $(@D)/.tmp_$(@F) $@;                \
  187.     fi;
  188. endif
  189.  
  190. define rule_cc_o_c
  191.     $(call echo-cmd,checksrc) $(cmd_checksrc)              \
  192.     $(call echo-cmd,cc_o_c) $(cmd_cc_o_c);                  \
  193.     $(cmd_modversions)                          \
  194.     scripts/basic/fixdep $(depfile) $@ '$(call make-cmd,cc_o_c)' >    \
  195.                                                   $(dot-target).tmp;  \
  196.     rm -f $(depfile);                          \
  197.     mv -f $(dot-target).tmp $(dot-target).cmd
  198. endef
  199.  
  200. # Built-in and composite module parts
  201.  
  202. %.o: %.c FORCE
  203.     $(call cmd,force_checksrc)
  204.     $(call if_changed_rule,cc_o_c)
  205.  
  206. # Single-part modules are special since we need to mark them in $(MODVERDIR)
  207.  
  208. $(single-used-m): %.o: %.c FORCE
  209.     $(call cmd,force_checksrc)
  210.     $(call if_changed_rule,cc_o_c)
  211.     @{ echo $(@:.o=.ko); echo $@; } > $(MODVERDIR)/$(@F:.o=.mod)
  212.  
  213. quiet_cmd_cc_lst_c = MKLST   $@
  214.       cmd_cc_lst_c = $(CC) $(c_flags) -g -c -o $*.o $< && \
  215.              $(CONFIG_SHELL) $(srctree)/scripts/makelst $*.o \
  216.                      System.map $(OBJDUMP) > $@
  217.  
  218. %.lst: %.c FORCE
  219.     $(call if_changed_dep,cc_lst_c)
  220.  
  221. # Compile assembler sources (.S)
  222. # ---------------------------------------------------------------------------
  223.  
  224. modkern_aflags := $(AFLAGS_KERNEL)
  225.  
  226. $(real-objs-m)      : modkern_aflags := $(AFLAGS_MODULE)
  227. $(real-objs-m:.o=.s): modkern_aflags := $(AFLAGS_MODULE)
  228.  
  229. quiet_cmd_as_s_S = CPP $(quiet_modtag) $@
  230. cmd_as_s_S       = $(CPP) $(a_flags)   -o $@ $< 
  231.  
  232. %.s: %.S FORCE
  233.     $(call if_changed_dep,as_s_S)
  234.  
  235. quiet_cmd_as_o_S = AS $(quiet_modtag)  $@
  236. cmd_as_o_S       = $(CC) $(a_flags) -c -o $@ $<
  237.  
  238. %.o: %.S FORCE
  239.     $(call if_changed_dep,as_o_S)
  240.  
  241. targets += $(real-objs-y) $(real-objs-m) $(lib-y)
  242. targets += $(extra-y) $(MAKECMDGOALS) $(always)
  243.  
  244. # Linker scripts preprocessor (.lds.S -> .lds)
  245. # ---------------------------------------------------------------------------
  246. quiet_cmd_cpp_lds_S = LDS     $@
  247.       cmd_cpp_lds_S = $(CPP) $(cpp_flags) -D__ASSEMBLY__ -o $@ $<
  248.  
  249. %.lds: %.lds.S FORCE
  250.     $(call if_changed_dep,cpp_lds_S)
  251.  
  252. # Build the compiled-in targets
  253. # ---------------------------------------------------------------------------
  254.  
  255. # To build objects in subdirs, we need to descend into the directories
  256. $(sort $(subdir-obj-y)): $(subdir-ym) ;
  257.  
  258. #
  259. # Rule to compile a set of .o files into one .o file
  260. #
  261. ifdef builtin-target
  262. quiet_cmd_link_o_target = LD      $@
  263. # If the list of objects to link is empty, just create an empty built-in.o
  264. cmd_link_o_target = $(if $(strip $(obj-y)),\
  265.               $(LD) $(ld_flags) -r -o $@ $(filter $(obj-y), $^),\
  266.               rm -f $@; $(AR) rcs $@)
  267.  
  268. $(builtin-target): $(obj-y) FORCE
  269.     $(call if_changed,link_o_target)
  270.  
  271. targets += $(builtin-target)
  272. endif # builtin-target
  273.  
  274. #
  275. # Rule to compile a set of .o files into one .a file
  276. #
  277. ifdef lib-target
  278. quiet_cmd_link_l_target = AR      $@
  279. cmd_link_l_target = rm -f $@; $(AR) $(EXTRA_ARFLAGS) rcs $@ $(lib-y)
  280.  
  281. $(lib-target): $(lib-y) FORCE
  282.     $(call if_changed,link_l_target)
  283.  
  284. targets += $(lib-target)
  285. endif
  286.  
  287. #
  288. # Rule to link composite objects
  289. #
  290. #  Composite objects are specified in kbuild makefile as follows:
  291. #    <composite-object>-objs := <list of .o files>
  292. #  or
  293. #    <composite-object>-y    := <list of .o files>
  294. link_multi_deps =                     \
  295. $(filter $(addprefix $(obj)/,         \
  296. $($(subst $(obj)/,,$(@:.o=-objs)))    \
  297. $($(subst $(obj)/,,$(@:.o=-y)))), $^)
  298.  
  299. quiet_cmd_link_multi-y = LD      $@
  300. cmd_link_multi-y = $(LD) $(ld_flags) -r -o $@ $(link_multi_deps)
  301.  
  302. quiet_cmd_link_multi-m = LD [M]  $@
  303. cmd_link_multi-m = $(LD) $(ld_flags) $(LDFLAGS_MODULE) -o $@ $(link_multi_deps)
  304.  
  305. # We would rather have a list of rules like
  306. #     foo.o: $(foo-objs)
  307. # but that's not so easy, so we rather make all composite objects depend
  308. # on the set of all their parts
  309. $(multi-used-y) : %.o: $(multi-objs-y) FORCE
  310.     $(call if_changed,link_multi-y)
  311.  
  312. $(multi-used-m) : %.o: $(multi-objs-m) FORCE
  313.     $(call if_changed,link_multi-m)
  314.     @{ echo $(@:.o=.ko); echo $(link_multi_deps); } > $(MODVERDIR)/$(@F:.o=.mod)
  315.  
  316. targets += $(multi-used-y) $(multi-used-m)
  317.  
  318.  
  319. # Descending
  320. # ---------------------------------------------------------------------------
  321.  
  322. PHONY += $(subdir-ym)
  323. $(subdir-ym):
  324.     $(Q)$(MAKE) $(build)=$@
  325.  
  326. # Add FORCE to the prequisites of a target to force it to be always rebuilt.
  327. # ---------------------------------------------------------------------------
  328.  
  329. PHONY += FORCE
  330.  
  331. FORCE:
  332.  
  333. # Read all saved command lines and dependencies for the $(targets) we
  334. # may be building above, using $(if_changed{,_dep}). As an
  335. # optimization, we don't need to read them if the target does not
  336. # exist, we will rebuild anyway in that case.
  337.  
  338. targets := $(wildcard $(sort $(targets)))
  339. cmd_files := $(wildcard $(foreach f,$(targets),$(dir $(f)).$(notdir $(f)).cmd))
  340.  
  341. ifneq ($(cmd_files),)
  342.   include $(cmd_files)
  343. endif
  344.  
  345.  
  346. # Declare the contents of the .PHONY variable as phony.  We keep that
  347. # information in a variable se we can use it in if_changed and friends.
  348.  
  349. .PHONY: $(PHONY)
  350.